
Mysql技术内幕之InnoDB锁的深入讲解
前言自7月份换工作以来,期间一直在学习MySQL的相关知识,听了一些视频课,但是一直好奇那些讲师的知识是从哪里学习的。于是想着从书籍中找答案。毕竟一直看视频也不是办法,不能形成自己的知识。于是想着看书汲取知识,看了几本MySQL的相关书籍,包括《深入浅出Mysql》《高性能Mysql》《Mysql...
2024-01-10
JDBC内幕subquery
subquery子查询指一个查询语句嵌套在另一个查询语句内部的查询,在 SELECT 子句中先计算子查询,子查询结果作为外层另一个查询的过滤条件,查询可以基于一个表或者多个表,子查询中常用的操作符有 ANY(SOME)、ALL、IN 和 EXISTS。常见形式如下数据中间件一般处理subquery思路是拆分SQL语句,先查询...
2024-01-10
BaikalDB技术实现内幕(一)分布式事务实现
本系列文章主要介绍HTAP数据库BaikalDB的技术实现细节。作者介绍:罗小兵,百度商业平台研发部高级研发工程师,主要负责BaikalDB事务能力,全局二级索引等方向的研发工作。欢迎关注 Star github.com/baidu/BaikalDB一、概述BaikalDB系统简介BaikalDB是一个分布式可扩展的存储系统,兼容MySQL协议,整个系统...
2024-01-10
mysql 批量修复
#!/bin/bashhost_name=127.0.0.1user_name=user_pwd=database=need_optmize_table=falsetables=$(/usr/local/webserver/mysql/bin/mysql -h$host_name -u$user_name -p$user_pwd $database -A -Bse "show tables")for table_name in $tablesdo check_result=$(/usr/local/webs...
2024-01-10
Mysql如何处理死锁
MySQL有两种死锁处理方式:等待,直到超时(innodb_lock_wait_timeout=50s)。发起死锁检测,主动回滚一条事务,让其他事务继续执行(innodb_deadlock_detect=on)。由于性能原因,一般都是使用死锁检测来进行处理死锁。死锁检测死锁检测的原理是构建一个以事务为顶点、锁为边的有向图,判断有向图是否存在...
2024-01-10
mysql入门(五)
SQL编程1).if-elseif-else语句语法:if 条件 then //条件1elseif 条件 then //条件2else //条件3end if;示例演示:create procedure pro_9(in grade int) -- 输入等级begin if grade=1 then select "最强王者" as "排位等级"; elseif grade=2 then select "超凡大师" as "排位等级"; el...
2024-01-10
mysql(一)
1 数据类型数据类型默认是有符号的(-128,127),没有符号的范围是(0,255)datetime(日期)float/double/decimal(浮点型)2 字符char(定长,存储速度快,但浪费空间大小)varchar(可变长度,节省空间,但存取速度慢)3表的约束约束的作用:保证数据的完整性和一致性包括:not null非空约束 default默认值约束 ...
2024-01-10
mysql组复制的应用场景
应用场景1、数据库的灵活复制环境。分组复制可以灵活地增加和减少集群中的数据库实例。2、数据库环境的高可用性。在集群中大部分服务器可用时,组复制允许数据库实例宕机,那么整个数据库服务可用。3、替代数据库环境中传统的主从复制结构。实例vim /etc/mysql.cnf先删掉之前实验加入的内容,...
2024-01-10
mysql需要购买么
MySQL是开源软件,但开源并不意味着完全免费,开源的优势可以使更多的人对代码改进和完善,但开源软件的使用应遵循该软件提供的使用授权协议。(推荐教程:mysql数据库学习教程)MySQL分社区版和商业版。社区版是免费的,商业版要收费。免费版本的mysql与收费版本的区别在于:免费版本的具有开...
2024-01-10
mysql端口号多少
MySQL是一种关系数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。mysql默认端口号是3306,可以编辑用户目录下的 .my.cnf 文件进行修改。推荐:MySQL教程1、mysql的默认端口是3306,可以编辑用户目录下的 .my.cnf 文件进行修改;2...
2024-01-10
mysql游标的介绍
说明1、游标是用来存储查询结果集的数据类型 , 在存储过程和函数中可以使用光标对结果集进行循环的处理。2、也可以将游标称之为光标。光标的使用包括声明光标、打开光标、使用光标和关闭光标。实例-- 通过存储过程查询emp表中数据, 并逐行获取进行展示create procedure pro_test11()begin --声明...
2024-01-10
mysql整理
1.在mysql数据库内如何让自动增加字段从0开始truncate table 表名2.表中有A B C三列时,用SQL语句实现:当A列大于B列时选择A列,否则选择B列,当B列大于C列时选择B,否则选择C列select case when A > B then A else B end, case when B > C then B else C end;3.RedisRedis是一个key-value存储系统。支持五种数据类型:(1)string(字符...
2024-01-10
mysql(三)
1 多表查询:创建一个部门表和员工表并插入数据代码块use company;#创建部门表CREATE TABLE department (id int PRIMARY key auto_increment,dep_name varchar(10) not null);#创建员工表CREATE TABLE employee(id int PRIMARY key auto_increment,emp_name varchar(10) not null,dep_id int-- CONSTRAINT dep_i...
2024-01-10
mysql查看备份文件的方法
说明1、mysqldump导出的SQL脚本是文本文件,/*···*/或--开头的部分表示注释信息。2、使用grep、lesscat等工具查看详细的脚本内容。3、将过滤auth.sql脚本中的数据库操作语句。实例[root@localhost ~]# grep -v "^--" auth.sql | grep -v "^/" | grep -v "^$"CREATE DATABASE /*!32312 IF NOT EXISTS*/ `auth` /*!40100 DEFAULT CHARACT...
2024-01-10
Mysql备份还有这么多套路,还不了解下?
逻辑备份和物理备份逻辑备份逻辑备份用于备份数据库的结构(CREAET DATABASE、CREATE TABLE)和数据(INSERT),这种备份类型适合数据量小、跨SQL服务器、需要修改数据等场景。如mysqldump命令就是产生一个逻辑备份工具,使用mysqldump输出的文件包含CREATE TABLE和INSERT语句,能够直接重建表内容和表结构。使...
2024-01-10
mysql物理备份如何理解
说明1、物理备份又分为冷备份和热备份两种。2、和逻辑备份相比,它的优点是备份和恢复的速度更快,因为物理备份的原理都是基于文件的cp。实例myisam存储引擎的热备份有很多方法,本质其实就是将要备份的表加读锁,然后再 cp 数据文件到备份目录。使用 mysqlhotcopy 工具// mysqlhotcopy 是 MySQL 的一...
2024-01-10
mysql备份脚本
脚本内容:db_user="root"db_passwd="123456"db_name="db_name"time="$(date +"%Y%m%d%H%M%S")"backupdir=/home/wbxt/mysql_backup/usr/local/mysql/bin/mysqldump -u$db_user -p$db_passwd $db_name >>$backupdir/$db_name$time.sqlfind $backupdir -name "$db_name*.sql" -type f...
2024-01-10
Mysql备份与恢复(2)逻辑备份
数据库及时备份可以帮助我们在数据库出现异常宕机时及时的使用备份数据进行恢复工作,将因为数据库宕机产生的影响降低到最小。上一篇针对使用xtrabackup工具进行物理备份和数据恢复做了一个详细讲解,本篇主要谈谈如何使用mysql自带的备份工具mysqldump进行逻辑备份和数据恢复。如果还围观看过上...
2024-01-10
mysql备份详细解
Mysqldump导出不含创建数据库的语句mysqldump -uroot -proot wms > 1.sql包含创建数据库的语句mysqldump -uroot -proot --databases wms > 1.sql//导出某张表mysqldump -uroot -proot wms wms_goods > 1.sql//导出binlog的位置并注释,且不锁表 single-transaction的作用是开启事务mysqldump -uroot -proot --master-data=2 --s...
2024-01-10
mysql定时备份任务
简介在生产环境上,为了避免数据的丢失,通常情况下都会定时的对数据库进行备份。而Linux的crontab指令则可以帮助我们实现对数据库定时进行备份。首先我们来简单了解crontab指令,如果你会了请跳到下一个内容mysql备份。本文章的mysql数据库是安装在docker容器当中,以此为例进行讲解。没有安装到do...
2024-01-10
Mysql实现企业级日志管理、备份与恢复的实战教程
背景随着业务的发展,公司业务和规模不断扩大,网站积累了大量的用户信息和数据,对于一家互联网公司来说,用户和业务数据是根基。一旦公司的数据错乱或者丢失,对于互联网公司而言就等于说是灭顶之灾,为防止系统出现操作失误或系统故障导致数据丢失,公司要求加强用户数据的可靠性,...
2024-01-10
减去月份和日期的mysql
我需要用mysql减去1个月DATE_ADD (NOW (), - 1 MONTH)零4天,我看到命令完美适用于1个月但1个月零4天,使用31天对于每个月带来30、29、28的每月无效。我无法添加31 + 4,30 + 4,等等回答:使用DATE_SUB [docs] 像:DATE_SUB((DATE_SUB(curdate(), INTERVAL 1 MONTH)), INTERVAL 4 DAY)...
2024-01-10
mysql逻辑备份有什么特点
备份是通过查询MySQL服务器获取数据库结构和内容信息。1、备份比物理方法慢,因为服务器必须访问数据库信息并将其转换为逻辑格式。如果输出写入客户端,服务器还必须将其发送到备份程序。2、输出大于物理备份,尤其是文本格式。备份和还原粒度可用于服务器级别(所有数据库)、数据库级别(特...
2024-01-10
如何将mysql表行转置为列
这是我当前的mysql表的样子:PunchID EmpID PunchEvent PunchDateTime1 0456 clockin 5/14/2013 8:36:26 AM48 0456 breakout 5/14/2013 12:01:29 PM53 0456 breakin 5/14/2013 12:28:31 PM54 0456 clockout 5/14/2013 2:28:33 PM57 ...
2024-01-10
Mysql表操作
数据之表操作创建表语法:CREATE TABLE table_name (column_name column_type);create table student( -> id INT NOT NULL AUTO_INCREMENT, -> name CHAR(32) NOT NULL, -> age INT NOT NULL, -> regiiter_date DATE, -> PRIMARY KEY(id) -> );auto_increment ...
2024-01-10
从mysql表中选择特定的行
理想情况下,我需要一个等于select * from customer where row_number() = 3但这是非法的。row_number()是需要选择的行。我该怎么办?编辑:嗯,我使用iSql *plus进行练习,出于某些原因,使用limit和auto_increment是非法的。我最终创建了一个序列和一个触发器,并且每次输入一个条目时,ID都增加了1。回答:...
2024-01-10
mysql如何创建临时表
mysql 利用 temporary 关键字就可以创建出一个临时表。创建的这张表会在与服务器的会话终止时自动消失。(推荐教程:mysql数据库学习教程)语法:create temporary table tbl_name...;规则:每个会话只能看到自己创建的临时表,不同的会话可以创建相同表名称的临时表。临时表的表名可以和永久表的名字相同...
2024-01-10
mysql如何高效快速整合两个表的内容?
需求A表中有70万数据,B表中有50万数据。现在要实现:将B表导入A表。A、B两个表中有一些重复数据,比如A表中有name='张三'这个字段,B表中也有name='张三'这个字段,则两个保留一个。若B表中有,A表中没有,则往A表中添加。我的实现while(B表中查出的数据不为空){ //查询出B表中的数据 //每次查询10...
2024-01-10![mysql如何创建临时表[mysql基础教程]](/wp-content/uploads/thumbs/681079_thumbnail.jpg)
mysql如何创建临时表[mysql基础教程]
mysql 利用 temporary 关键字就可以创建出一个临时表。创建的这张表会在与服务器的会话终止时自动消失。(推荐教程:mysql数据库学习教程)语法:create temporary table tbl_name...;规则:每个会话只能看到自己创建的临时表,不同的会话可以创建相同表名称的临时表。临时表的表名可以和永久表的名字相同...
2024-01-10
mysql表导出的两种方法
1、使用select ...into outfile ... 命令来导出数据 mysql> select * from tablename into outfile 'target_file' [option];其中 option 参数可以是以下选项:fields terminated by 'string' // 字段分隔符,默认为制表符'\t'fields [optionally] enclosed by 'char' // 字段引用符,如果加 op...
2024-01-10
将CSV导入mysql表
将csv文件上传到mysql表的最佳/最快方法是什么?我想将第一行数据用作列名。发现了这一点:如何将CSV文件导入MySQL表但是唯一的答案是使用GUI而不是Shell?回答:您无需编写脚本即可从CSV文件中提取信息,而是可以直接将MYSQL链接到该文件并使用以下SQL语法上传信息。要将Excel文件导入MySQL,请先将...
2024-01-10
mysql如何在表中新增一列
具体方法:(推荐教程:mysql数据库学习教程)在一个已经创建好的表中新增一列:alter table TABLE_NAME add column NEW_COLUMN_NAME varchar(45) not null;这条语句向已有的表中加入新的一列,这一列在表的最后一列位置。如果希望添加在指定的一列,可以用:alter table TABLE_NAME add column NEW_COLUMN_NAME varchar(45) ...
2024-01-10
一种简单的ID生成策略: Mysql表生成全局唯一ID的实现
生成全局ID的方法很多, 这里记录下一种简单的方案: 利用mysql的自增id生成全局唯一ID.1. 创建一张只需要两个字段的表:CREATE TABLE `guid` ( `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, `stub` char(1) NOT NULL DEFAULT '' COMMENT '桩字段,占坑的', PRIMARY KEY (`id`), UNIQUE KEY `uk_stub` (`stub`) -- 将 stub 设为唯一索...
2024-01-10
